import { getToken, setToken, removeToken, setTimeStamp } from '@/utils/auth'
import { login, getUserInfo, getUserDetailById } from '@/api/user'
import { resetRouter } from '@/router'
// 状态
const state = {
  token: getToken(),
  userInfo: {}
}
// 修改状态
const mutations = {
  // 设置token
  setToken(state, token) {
    state.token = token
    setToken(token)
  },
  // 删除 token
  removeToken(state) {
    state.token = null // 删除 vuex 的token
    removeToken()
  },
  // 设置用户资料
  setUserInfo(state, userInfo) {
    state.userInfo = { ...userInfo }
  },
  // 删除用户信息
  reomveUserInfo(state) {
    state.userInfo = {}
  }
}
// 执行异步
const actions = {
  async login(context, data) {
    // 经过响应拦截器的处理之后 这里的result实际上就是 token
    const result = await login(data)
    console.log(result)
    // axios默认给数据加了一层data
    // 表示登录接口调用成功 也就是意味着你的用户名和密码是正确的
    // 现在有用户token
    // actions 修改state 必须通过mutations
    context.commit('setToken', result)

    setTimeStamp()
  },
  async getUserInfo(context) {
    // 获取用户资料
    const result = await getUserInfo() // 获取返回值
    const baseInfo = await getUserDetailById(result.userId)
    context.commit('setUserInfo', { ...result, ...baseInfo })
    return result
  },
  logout(context) {
    context.commit('removeToken')
    context.commit('reomveUserInfo')
    // 重置路由
    resetRouter()
    // 重置菜单
    context.commit('permission/setRoutes', [], { root: true }) // 站在根模块的角度去调用
  }
}
export default {
  namespaced: true,
  state,
  mutations,
  actions
}
